草庐IT

php - 查询数据库时收到重复的答案

全部标签

ruby-on-rails - 两次之间的 Rails 查询

我有一个Rails应用程序,它有一个Checkin模型。我想查找当天特定时间范围内的所有记录。我将如何编写where来获取在中午12点到下午4:30之间创建的所有记录? 最佳答案 @x1a4的答案应该对你有好处,但你可以使用范围以更易读和更短的方式来完成。Checkin.where(created_at:Time.parse("12pm")..Time.parse("4:30pm"))它应该生成如下内容:SELECT"checkins".*FROM"checkins"WHERE("checkins"."created_at"BETW

ruby-on-rails - 强制所有收到的请求 Content-Type 为 JSON

我实际上正在开发一个使用Rails4的API。如果客户端未在中指定媒体类型,我想将请求的Content-Type设置为JSONContent-Typeheader。为了获得这种行为,我尝试在我的ApplicationController中添加以下before_action:defset_request_default_content_typerequest.format=:jsonend在我的RegistrationsController#create方法中,我有一个断点来检查是否一切正常。嗯,request.format技巧不起作用,尽管值设置为application/json似乎C

ruby - 在 Ruby + TinyTDS 中参数化 SQL 查询

我试图弄清楚如何在将SQL字符串交给执行之前对其进行参数化,但遗憾的是我发现了很多ofthis在互联网上:sql="SELECT*FROMtable_nameWHEREthingLIKE'%#{input}%'"这是一件坏事...但是,参数化sql查询在底层可用Sequel库,这是TinyTDS构建的基础。所以我知道这是可能的。我只是很难弄明白。我真的希望它能像this一样简单:@client=TinyTds::Client.new(:adapter=>'sqlserver',:host=>host,:database=>db,:username=>username,:password

ruby-on-rails - 如何编写 Devise 扩展(使用自定义数据存储)

我想为Devise编写一个扩展,允许您使用parse_resource作为数据存储(与ActiveRecord相反)。parse_resource是Parse.com的RESTapi的Ruby包装器。它的界面与ActiveRecord的界面几乎相同,并且是ActiveModel的提示。因此,Devise的扩展似乎可能不需要太多非样板文件。但是,我找不到任何教程。我必须依赖的是其他扩展的来源。来自MongoMapperextension,我认为有两个主要部分:Thegenerators(不是很需要)在这里你覆盖了DeviseGenerator#(generate_model|inject

ruby-on-rails - 如何构建我的 RSpec 测试文件夹、文件和数据库?

我已经使用RoR进行开发一年多了,但我才刚刚开始使用RSpec进行测试。对于标准模型/Controller测试,我通常没有任何问题,但问题是我想测试一些复杂的功能流程,并且不知道如何构建我的测试文件夹/文件/数据库。这是我的应用程序的基本结构:classCustomerhas_one:wallethas_many:ordershas_many:invoices,through::ordershas_many:invoice_summariesendclassWalletbelongs_to:customerendclassOrderhas_one:invoicebelongs_to:c

sql - rails union hack,如何将两个不同的查询放在一起

我有一个查询,它在同一个表中搜索两个单独的字段...寻找最有可能是特定城市但也可能是国家的位置...即需要两个字段。表格看起来像:CountryCityGermanyAachenUSAAmarilloUSAAustin结果:KeywordSideinfoAachenGermanyUSACountryAustinUSAGermanyCountry基本上我想知道是否有更简洁的方法来执行此操作,因为我必须使用两个单独的查询,然后将它们加在一起,对它们进行排序等(效果很好):defself.ajax(search)countries=Location.find(:all,:select=>'c

ruby-on-rails - 防止 Rails 测试删除种子数据

我正在使用seeds.rb填充一些状态模型引用数据:State.create:name=>'Alabama',:abbreviation=>'AL'State.create:name=>'Alaska',:abbreviation=>'AK'#...虽然我没有使用状态固定装置(因为它是种子数据,我认为纯粹为了测试而复制它不会是DRY),Rails测试框架似乎删除了所有状态种子数据测试。(我正在删除、重新创建、迁移和重新播种测试数据库,并在单元测试运行之前确认数据在那里。)结果是此断言在seeds.rb中成功但在单行测试中失败:assert_equal51,State.all.size1

sql - Rails 中独立于数据库的 SQL 字符串连接

我想在Rails查询中进行数据库端字符串连接,并以独立于数据库的方式进行。SQL-92指定双杠(||)作为连接运算符。不幸的是,MSSQLServer似乎不支持它;它使用+代替。我猜Rails的SQL语法抽象已经解决了特定于数据库的运算符问题。如果它确实存在,我该如何使用它? 最佳答案 我遇到了同样的问题,但从未想出任何内置于Rails中的东西。所以我写了这个小方法。#Symbolsshouldbeusedforfieldnames,everythingelsewillbequotedasastringdefdb_concat(*a

ruby - 从 Ruby 数组中删除顺序重复项

假设我有以下数组,我想去掉连续的重复项:arr=[1,1,1,4,4,4,3,3,3,3,5,5,5,1,1,1]我想得到以下信息:=>[1,4,3,5,1]如果有比我的解决方案(或其变体)更简单、更高效的东西,那就太好了:(arr+[nil]).each_cons(2).collect{|i|i[0]!=i[1]?i[0]:nil}.compact或(arr+[nil]).each_cons(2).each_with_object([]){|i,memo|memo编辑:看起来@ArupRakshit下面的解决方案非常简单。我仍在寻找比我的解决方案更高效的方法。编辑:我将在响应出现时对

ruby-on-rails - var_dump 并像 php 一样死去,在 ruby​​ on rails 中(在 ruby​​ on rails 中调试)

这可能是重复的问题。但是我无法显示对象。我是ruby​​的新手,尝试过像var_dump和print_r这样的调试,然后在php中die/p>这是我的代码。@brand_id=Brand.maximum("brand_id")我试过下面的方法1putsYAML::dump(@brand_id)2logger.debug{@brand_id.inspect}请问谁能帮我解决一下吗? 最佳答案 Rails只会将View输出到浏览器。任何其他输出都发送到服务器上的STD_OUT。从View中调试很简单:但是从Controller或模型内部